@import "open-color/open-color.scss";

.color-picker {
  background: $oc-white;
  border: 0px solid transparentize($oc-white, 0.75);
  box-shadow: transparentize($oc-black, 0.75) 0px 1px 4px;
  border-radius: 4px;
  position: absolute;
  :root[dir="ltr"] & {
    left: -5.5px;
  }
  :root[dir="rtl"] & {
    right: -5.5px;
  }
}

.color-picker-control-container {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
}

.color-picker-triangle {
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 0px 9px 10px;
  border-color: transparent transparent $oc-white;
  position: absolute;
  top: -10px;
  :root[dir="ltr"] & {
    left: 12px;
  }
  :root[dir="rtl"] & {
    right: 12px;
  }
}

.color-picker-triangle-shadow {
  border-color: transparent transparent transparentize($oc-black, 0.9);
  top: -11px;
}

.color-picker-content {
  padding: 0.5rem;
  display: grid;
  grid-template-columns: repeat(5, auto);
  grid-gap: 0.5rem;
}

.color-picker-content .color-input-container {
  grid-column: 1 / span 5;
}

.color-picker-swatch {
  position: relative;
  height: 1.875rem;
  width: 1.875rem;
  cursor: pointer;
  border-radius: 4px;
  margin: 0;
  box-sizing: border-box;
  border: 1px solid #ddd;
  background-color: currentColor !important;
}

.color-picker-swatch:focus {
  /* TODO: only show the border when the color is too light to see as a shadow */
  box-shadow: 0 0 4px 1px currentColor;
  border-color: $oc-blue-5;
}

.color-picker-transparent {
  border-radius: 4px;
  box-shadow: transparentize($oc-black, 0.9) 0px 0px 0px 1px inset;
  position: absolute;
  top: 0px;
  right: 0px;
  bottom: 0px;
  left: 0px;
}
.color-picker-transparent,
.color-picker-label-swatch {
  background: url("")
    left center;
}

.color-picker-hash {
  background: $oc-gray-3;
  height: 1.875rem;
  width: 1.875rem;
  :root[dir="ltr"] & {
    border-radius: 4px 0px 0px 4px;
  }
  :root[dir="rtl"] & {
    border-radius: 0px 4px 4px 0px;
  }
  color: $oc-gray-7;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  position: relative;
}
.color-input-container:focus-within .color-picker-hash {
  box-shadow: 0 0 0 2px $oc-blue-2;
}
.color-input-container:focus-within .color-picker-hash::before,
.color-input-container:focus-within .color-picker-hash::after {
  content: "";
  width: 1px;
  height: 100%;
  position: absolute;
  top: 0;
}
.color-input-container:focus-within .color-picker-hash::before {
  background: $oc-gray-3;
  :root[dir="ltr"] & {
    right: -1px;
  }
  :root[dir="rtl"] & {
    left: -1px;
  }
}
.color-input-container:focus-within .color-picker-hash::after {
  background: #fff;
  :root[dir="ltr"] & {
    right: -2px;
  }
  :root[dir="rtl"] & {
    left: -2px;
  }
}

.color-input-container {
  display: flex;
}

.color-picker-input {
  width: 12ch; /* length of `transparent` + 1 */
  margin: 0;
  font-size: 1rem;
  color: $oc-gray-8;
  border: 0px;
  outline: none;
  height: 1.75em;
  box-shadow: $oc-gray-3 0px 0px 0px 1px inset;
  :root[dir="ltr"] & {
    border-radius: 0px 4px 4px 0px;
  }
  :root[dir="rtl"] & {
    border-radius: 4px 0px 0px 4px;
  }
  float: left;
  padding: 1px;
  padding-inline-start: 0.5em;
  appearance: none;
}

.color-picker-label-swatch {
  height: 1.875rem;
  width: 1.875rem;
  margin-inline-end: 0.25rem;
  border: 1px solid $oc-gray-3;
  position: relative;
  overflow: hidden;
  background-color: transparent !important;
}

.color-picker-label-swatch::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--swatch-color);
}

.color-picker-keybinding {
  position: absolute;
  bottom: 2px;
  :root[dir="ltr"] & {
    right: 2px;
  }
  :root[dir="rtl"] & {
    left: 2px;
  }
  font-size: 0.7em;
  color: #ccc;
}
